- [reg]: contents of the register
- imm: 16-bit immediate field of the I-type instruction
- addr: 26-bit address field of the J-type instruction
- SignImm: 32-bit sign-extended immediate = {{16{imm[15]}}, imm}
- ZeroImm: 32-bit zero-extended immediate = {16'b0, imm}
- Address: [rs] + SignImm // ±imm [unit of bytes]
- [Address]: contents of memory location Address
- BTA: branch target address = PC + 4 + (SignImm << 2) //±imm [unit of words]
- JTA: jump target address =  $\{(PC + 4)[31:28], addr, 2'b0\}//addr [unit of words]$
- label: text indicating an instruction location // lable is address in unit of bytes

## l-type, J-type פקודות



| Opcode                    | Name                               | Description                                                   | Operation                                                   |
|---------------------------|------------------------------------|---------------------------------------------------------------|-------------------------------------------------------------|
| 000000 (0)                | R-type                             | all R-type instructions                                       | see Table B.2                                               |
| 000001 (1)<br>(rt = 0/1)  | bltz rs, label /<br>bgez rs, label | branch less than zero/branch<br>greater than or equal to zero | if ([rs] < 0) PC = BTA/<br>if ([rs] ≥ 0) PC = BTA           |
| 000010 (2)                | j label                            | jump                                                          | PC = JTA                                                    |
| 000011 (3)                | jal label                          | jump and link                                                 | ra = PC + 4, $PC = JTA$                                     |
| 000100 (4)                | beq rs, rt, label                  | branch if equal                                               | if ([rs] == [rt]) PC = BTA                                  |
| 000101 (5)                | bne rs, rt, label                  | branch if not equal                                           | if ([rs] != [rt]) PC = BTA                                  |
| 000110 (6)                | blez rs, label                     | branch if less than or equal to zero                          | if ([rs] $\leq$ 0) PC = BTA                                 |
| 000111 (7)                | bgtz rs, label                     | branch if greater than zero                                   | if([rs]>0)PC=BTA                                            |
| 001000 (8)                | addirt,rs,imm                      | add immediate                                                 | [rt] = [rs] + SignImm                                       |
| 001001 (9)                | addiu rt, rs, imm                  | add immediate unsigned                                        | [rt] = [rs] + SignImm                                       |
| 001010 (10)               | sltirt,rs,imm                      | set less than immediate                                       | [rs] < SignImm ? [rt] = 1 : [rt] =                          |
| 001011 (11)               | sltiurt,rs,imm                     | set less than immediate unsigned                              | [rs] < SignImm ? [rt] = 1 : [rt] =                          |
| 001100 (12)               | andirt,rs,imm                      | and immediate                                                 | [rt] = [rs] & ZeroImm                                       |
| 001101 (13)               | ori rt, rs, imm                    | or immediate                                                  | [rt] = [rs]   ZeroImm                                       |
| 001110 (14)               | xori rt, rs, imm                   | xor immediate                                                 | [rt] = [rs] ^ ZeroImm                                       |
| 001111 (15)               | lui rt, imm                        | load upper immediate                                          | [rt] = {imm, 16'b0}                                         |
| 010000 (16)<br>(rs = 0/4) | mfc0 rt, rd/<br>mtc0 rt, rd        | move from/to coprocessor 0                                    | <pre>[rt] = [rd]/[rd] = [rt] (rd is in coprocessor 0)</pre> |
| 010001 (17)               | F-type                             | fop = 16/17: F-type instructions                              | see Table B.3                                               |
| 010001 (17)<br>(rt = 0/1) | bc1f label/<br>bc1t label          | fop = 8: branch if fpcond is<br>FALSE/TRUE                    | if (fpcond == 0) PC = BTA/<br>if (fpcond == 1) PC = BTA     |
| 011100 (28)<br>(func = 2) | mul rd, rs, rt                     | multiply (32-bit result)                                      | [rd] = [rs] x [rt]                                          |
| 100000 (32)               | lb rt, imm(rs)                     | load byte                                                     | [rt] = SignExt ([Address] <sub>7:0</sub> )                  |
| 100001 (33)               | lh rt, imm(rs)                     | load halfword                                                 | <pre>[rt] = SignExt ([Address]<sub>15:0</sub>)</pre>        |
| 100011 (35)               | lw rt, imm(rs)                     | load word                                                     | [rt] = [Address]                                            |
| 100100 (36)               | lburt, imm(rs)                     | load byte unsigned                                            | [rt] = ZeroExt ([Address] <sub>7:0</sub> )                  |
| 100101 (37)               | lhu rt, imm(rs)                    | load halfword unsigned                                        | <pre>[rt] = ZeroExt ([Address]<sub>15:0</sub>)</pre>        |
| 101000 (40)               | sbrt, imm(rs)                      | store byte                                                    | [Address] <sub>7:0</sub> = [rt] <sub>7:0</sub>              |
| 101001 (41)               | sh rt, imm(rs)                     | store halfword                                                | [Address] <sub>15:0</sub> = [rt] <sub>15:0</sub>            |
| 101011 (43)               | sw rt, imm(rs)                     | store word                                                    | [Address] = [rt]                                            |
| 110001 (49)               | lwc1 ft, imm(rs)                   | load word to FP coprocessor 1                                 | [ft] = [Address]                                            |
| 111001 (56)               | swc1 ft, imm(rs)                   | store word to FP coprocessor 1                                | [Address] = [ft]                                            |

## פקודות R-type

| Funct       | Name              | Description                     | Operation                             |
|-------------|-------------------|---------------------------------|---------------------------------------|
| 000000 (0)  | sll rd, rt, shamt | shift left logical              | [rd] = [rt] << shamt                  |
| 000010 (2)  | srl rd, rt, shamt | shift right logical             | [rd] = [rt] >> shamt                  |
| 000011 (3)  | sra rd, rt, shamt | shift right arithmetic          | [rd] = [rt] >>> shamt                 |
| 000100 (4)  | sllv rd, rt, rs   | shift left logical variable     | [rd] = [rt] << [rs] <sub>4:0</sub>    |
| 000110 (6)  | srlv rd, rt, rs   | shift right logical variable    | $[rd] = [rt] >> [rs]_{4:0}$           |
| 000111 (7)  | srav rd, rt, rs   | shift right arithmetic variable | [rd] = [rt] >>> [rs] <sub>4:0</sub>   |
| 001000 (8)  | jrrs              | jump register                   | PC = [rs]                             |
| 001001 (9)  | jalr rs           | jump and link register          | \$ra = PC + 4, PC = [rs]              |
| 001100 (12) | syscall           | system call                     | system call exception                 |
| 001101 (13) | break             | break                           | break exception                       |
| 010000 (16) | mfhi rd           | move from hi                    | [rd] = [hi]                           |
| 010001 (17) | mthi rs           | move to hi                      | [hi] = [rs]                           |
| 010010 (18) | mflo rd           | move from lo                    | [rd] = [lo]                           |
| 010011 (19) | mtlo rs           | move to lo                      | [10] = [rs]                           |
| 011000 (24) | mult rs, rt       | multiply                        | $\{[hi], [lo]\} = [rs] \times [rt]$   |
| 011001 (25) | multurs, rt       | multiply unsigned               | {[hi], []o]} = [rs] × [rt]            |
| 011010 (26) | div rs, rt        | divide                          | [lo] = [rs]/[rt],<br>[hi] = [rs]%[rt] |
| 011011 (27) | divu rs, rt       | divide unsigned                 | [lo] = [rs]/[rt],<br>[hi] = [rs]%[rt] |
| 100000 (32) | add rd, rs, rt    | add                             | [rd] = [rs] + [rt]                    |
| 100001 (33) | addu rd, rs, rt   | add unsigned                    | [rd] = [rs] + [rt]                    |
| 100010 (34) | sub rd, rs, rt    | subtract                        | [rd] = [rs] - [rt]                    |
| 100011 (35) | subu rd, rs, rt   | subtract unsigned               | [rd] = [rs] - [rt]                    |
| 100100 (36) | and rd, rs, rt    | and                             | [rd] = [rs] & [rt]                    |
| 100101 (37) | or rd, rs, rt     | or                              | [rd] = [rs]   [rt]                    |
| 100110 (38) | xor rd, rs, rt    | xor                             | [rd] = [rs] ^ [rt]                    |
| 100111 (39) | nor rd, rs, rt    | nor                             | [rd] = ~([rs]   [rt])                 |
| 101010 (42) | slt rd, rs, rt    | set less than                   | [rs] < [rt] ? [rd] = 1 : [rd] = 0     |
| 101011 (43) | sltu rd, rs, rt   | set less than unsigned          | [rs] < [rt] ? [rd] = 1 : [rd] = 0     |